package com.qfedu.fmmall.service.impl;

import com.qfedu.fmmal.utils.Base64Utils;
import com.qfedu.fmmal.utils.MD5Utils;
import com.qfedu.fmmal.vo.ResStatus;
import com.qfedu.fmmal.vo.ResultVO;
import com.qfedu.fmmall.dao.UsersMapper;
import com.qfedu.fmmall.entity.Users;
import com.qfedu.fmmall.service.UserService;

import io.jsonwebtoken.JwtBuilder;
import io.jsonwebtoken.Jwts;
import io.jsonwebtoken.SignatureAlgorithm;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import tk.mybatis.mapper.entity.Example;

import java.util.Date;
import java.util.HashMap;
import java.util.List;

@Service
public class UserServiceImpl implements UserService {

    @Autowired
    private UsersMapper usersMapper;

    @Transactional
    public ResultVO userRegist(String name, String pwd){
        synchronized (this) {
            //1.根据用户查询，这个用户是否已被注册
            Example example = new Example(Users.class);
            Example.Criteria criteria = example.createCriteria();
            criteria.andEqualTo("username",name);
            List<Users> users = usersMapper.selectByExample(example);

            //2.如果没有被注册，则进行保存操作
            if (users.size() == 0) {
                String md5Pwd = MD5Utils.md5(pwd);
                Users user = new Users();
                user.setUsername(name);
                user.setPassword(md5Pwd);
                user.setUserImg("img/default.png");
                user.setUserRegtime(new Date());
                user.setUserModtime(new Date());
                int i = usersMapper.insertUseGeneratedKeys(user);
                if (i > 0){
                    return new ResultVO(ResStatus.OK,"注册成功！",user);
                }else {
                    return new ResultVO(ResStatus.NO,"注册失败！",null);
                }
            } else {
                return new ResultVO(ResStatus.NO, "用户名已经被注册", null);
            }
        }
    }

    @Override
    public ResultVO checkLogin(String name, String pwd) {
        //1.根据账号查询用户信息
        Example example = new Example(Users.class);
        Example.Criteria criteria = example.createCriteria();
        criteria.andEqualTo("username",name);
        List<Users> users = usersMapper.selectByExample(example);

        //2.判断。如果user=null则错误
        if (users.size() == 0){
            //用户名不存在
            return new ResultVO(ResStatus.NO,"登录失败，用户名不存在",null);
        }else {
            //3.对输入的密码进行加密
            String md5Pwd = MD5Utils.md5(pwd);

            //4.使用加密后的密码 和 user中的密码进行匹配。
            if (md5Pwd.equals(users.get(0).getPassword())){
                HashMap<String,Object> map = new HashMap<>();

                map.put("key1","value1");
                map.put("key2","value2");

                //如果登录验证成功，则需要生成令牌token（token就是按照特定规则生成的字符串）
                //使用jwt规则生成token字符串
                JwtBuilder builder = Jwts.builder();
                String token = builder.setSubject(name)    //主题就是token中携带的数据
                        .setIssuedAt(new Date())    //设置token的生成时间
                        .setId(users.get(0).getUserId() + "")    //设置用户id为token的id
                        .setClaims(map)         //map中可以存放用户的角色权限信息
                        .setExpiration(new Date(System.currentTimeMillis() + 24 * 60 * 60 * 1000)) //设置token过期时间
                        .signWith(SignatureAlgorithm.HS256,"q666") //设置加密方式和加密密码
                        .compact();
                System.out.println(token);

                //验证成功
                return new ResultVO(ResStatus.OK,token,users.get(0));
            }else {
                //密码错误
                return new ResultVO(ResStatus.NO,"登录失败，密码错误！",null);
            }

        }

    }
}